阅读更多
acl 3.0.18 版本发布了。acl 是 one Advanced C/C++ library 的简称,主要包括网络通信库以及服务器框架库等功能,支持 Linux/Windows 平台。

项目主页:https://sourceforge.net/projects/acl/
技术文章主页:http://zsxxsz.ietye.com/

整个 acl 项目主要包含三个函数库:

  • lib_acl:纯C开发的最基础库,主要包含网络通信及服务器编程框架以及其它丰富的功能)
  • lib_protocol:包含 HTTP/PING/SMTP 通信协议的C语言实现
  • lib_acl_cpp:基于 lib_acl 及 lib_protocol 两个C库,提供了更为强大的编程接口及丰富的功能类

acl 包括以下丰富的常用函数库:

  1. 常见网络应用库: SMTP 客户端库/PING 库/memcache 客户端库/handlersocket 客户端库/beanstalk 客户端库
  2. HTTP 网络库:HTTP 客户端/服务端库,C++版 HttpServlet 类,HTTP COOKIE/HTTP SESSION 等
  3. 邮件解析库:mime解析库/RFC2047/RFC2048/mime base64/mime qp/mime uucode 等
  4. 网络通信库:阻塞/非阻塞网络 IO 库(其中 lib_acl_cpp 库通过嵌入 polarssl 而具备了 SSL 的能力)
  5. 服务器框架:包括进程池模式、线程池模式、非阻塞模式、UDP通信模式及触发器模式
  6. 事件引擎:支持 select、poll(for unix)、epoll(for linux)、kqueue(for bsd)、devpoll(for solaris)、iocp(for win32)、win32 窗口消息(for win32)事件引擎
  7. 通用连接池库:高效的连接池基础类库,支持丰富的功能
  8. 数据库客户端库:对原生的数据库客户端库进行了二次封装,使编程更为简易,功能更为丰富
  9. xml/json 流式解析库:区别于网上其它已有的 xml/json 解析库,acl 中的 xml/json 解析库采用有限状态机方式解析数据,处理方式更为灵活

本次 acl 升级除了一些 bug 修复外,主要优化了 ACL 中的网络服务器框架、事件引擎以及线程池调度算法,同时增加了客户端连接分发器模块。

一、基础 C 库 lib_acl改进

  • 新特性:线程池中(acl_thread_pool.c)的子线程的等待时间间隔分成多个等待时间片
  • 新特性:服务器模板(acl_aio_server.c, acl_thread_server.c)支持向连接分发器报告状态,从而允许从连接派发器处接收客户端连接
  • 新特性:借鉴了 glib 库中的一些宏定义,针对 gcc 或 vc 编译器增加了一些编译属性开关(如过期 API 调用警告)
  • 性能优化:线程池调度算法优化(每一个线程一个独立的线程条件变量,从而可以有效地避免线程池事件通知时的惊群现象)
  • 性能优化:事件引擎支持检测全部套接字的时间间隔设置,当并发连接较大时,可以有效地提升事件检测的性能
  • 性能优化:禁用事件引擎中的自旋锁,降低 CPU 损耗
  • 问题修复:acl_vstream_net.c 中 acl_vstream_accept_ex 接收外来连接时,判断监听描述符的类型方式有误
  • 问题修复:acl_getpeername 函数当客户端连接的是域套接字时,给出的地址不对
  • 问题修复:acl_master 服务器模块在 reload 配置文件时有可能会导致产生 core 文件
  • 问题修复:events_epoll_thr.c 在函数 event_disable_readwrite 中调用 epoll_ctl 删除描述字时,也必须保证第四个参数(struct epoll_event*) 非空,否则在低版
  • 本 LINUX 下会有问题
  • 问题修复:events_iocp.c 关闭未决状态的完成端口在 WIN XP 下存在 BUG,应该在套接字关闭前先取得完成端口状态

二、lib_acl_cpp 库改进

  • 新特性:connect_manager 连接池集群管理器增加了后台检测功能,新增加的类 connect_monitor 为一个非阻塞线程,会在后台定期检测连接池集群中的所有服务器的端口是否存活
  • 新特性:借鉴了 glib 库中的一些宏定义,针对 gcc 或 vc 编译器增加了一些编译属性开关(如过期 API 调用警告)
  • 新特性:db_pool 类增加了 peek_open 方法,可以在获取数据库对象时直接打开数据库连接
  • 新特性:将 master_threads 替换为 master_threads2
  • 问题修复:md5.cpp 其中在 WIN32 下使用 sprintf_s 函数时,传入的长度参数应为 3,否则 VC 会报错
  • 问题修复:event_timer.cpp, 在 32 位机下会因 64 位整数转 32 位整数而导致 32 位整数溢出问题
  • 问题修复:master_threads/master_threads2 存在内存泄露问题

三、app/master_dispatch改进

  • 增加了客户端连接分发器模块,通过该模块,可以非常均匀地将客户端连接分发给使用 acl 服务器框架的应用子进程

技术博客:http://zsxxsz.iteye.com/
下载:http://sourceforge.net/projects/acl/
SVN:svn checkout svn://svn.code.sf.net/p/acl/code/trunk acl-code
Github:https://github.com/zhengshuxin/acl
1
0
评论 共 2 条 请登录后发表评论
2 楼 zsxxsz 2014-04-09 19:48
谢谢提醒,不过应该是iteye的编辑给搞错了,请参考一下:http://zsxxsz.iteye.com/blog/2041841,同时和这篇资讯发出的。
1 楼 zjumty 2014-04-09 15:50
技术文章主页的URL错了

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

Global site tag (gtag.js) - Google Analytics